package com.talent.mapper;

import com.talent.pojo.entity.Category;
import jakarta.validation.constraints.NotBlank;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

import java.util.List;

/**
 * 分类Mapper
 */
@Mapper
public interface CategoryMapper {

    /**
     * 根据类型查询分类列表
     */
    List<Category> getByType(@Param("type") String type);

    /**
     * 根据ID查询分类
     */
    Category getById(Long id);

    /**
     * 新增分类
     */
    void insert(Category category);

    /**
     * 更新分类
     */
    void update(Category category);

    /**
     * 删除分类
     */
    void deleteById(Long id);

    /**
     * 统计分类数量（带关联点位数量）
     */
    List<Category> getWithSpotCount(@Param("type") String type);

    /**
     * 根据类型统计分类数量
     */
    Integer countByType(@Param("type") String type);

    @Select("select * from categories where name = #{name} limit 1")
    Category getByName(@NotBlank(message = "分类名称不能为空") String name);
}
